# MIPS project

- Design Specification
- Hardware
  - Cache Implementation
  - MIPS Implementation
    - Instructions
    - Hazard Handling
  - Performance

# Instructions supported

| Description                                                          |
|----------------------------------------------------------------------|
| Addition, overflow detection for signed operand is not required*     |
| Addition immediate with sign-extension, without overflow detection*  |
| Subtract, overflow detection for signed operand is not required*     |
| Boolean logic operation                                              |
| Boolean logic operation, zero-extension for upper 16bit of immediate |
| Boolean logic operation                                              |
| Boolean logic operation, zero-extension for upper 16bit of immediate |
| Boolean logic operation                                              |
| Boolean logic operation, zero-extension for upper 16bit of immediate |
| Boolean logic operation                                              |
| Shift left logical (zero padding)                                    |
| Shift right arithmetic (sign-digit padding)                          |
| Shift right logical (zero padding)                                   |
| Set less than, comparison instruction                                |
| Set less than variable, comparison instruction                       |
| Branch on equal, conditional branch instruction                      |
| Unconditionally jump                                                 |
| Unconditionally jump and link (Save next PC in \$r31)                |
| Unconditionally jump to the instruction whose address is in \$rs     |
| Jump and link register                                               |
| Load word from data memory (assign word-aligned)                     |
| Store word to data memory (assign word-aligned)                      |
| No operation                                                         |
|                                                                      |

# Pipeline Stages



- Design Specification
- Hardware
  - Cache Implementation
  - MIPS Implementation
    - Instructions
    - Hazard Handling
  - Performance



#### Cache

- Arrangement
  - 32-bit word
  - 4-word block, 8 blocks
  - 1-way cache
  - Write back, write allocate
    - Use valid as a dirty bit
    - Cache value change: set valid to 0
    - Reset: set valid to 1, avoid writing back invalid data to memory
    - Known issue: need a separate dirty bit

| Tag(25)  | Index(3) | offset(2) |           |           |           |
|----------|----------|-----------|-----------|-----------|-----------|
|          |          |           |           |           |           |
| Valid(1) | Tag(25)  | Word1(32) | Word1(32) | Word1(32) | Word1(32) |

# Cache





- Design Specification
- Hardware
  - Cache Implementation
  - MIPS Implementation
    - Instructions
    - Hazard Handling
  - Performance

|      |      |                                                                      |        |       | ac    | ldr(26)(J typ | pe)           |          |
|------|------|----------------------------------------------------------------------|--------|-------|-------|---------------|---------------|----------|
|      |      |                                                                      |        |       |       | СО            | nst(16)(I typ | oe)      |
| Name | Туре | Description                                                          | OP(6)  | rs(5) | rt(5) | rd(5)         | shamt(5)      | funct(6) |
| ADD  | R    | Addition, overflow detection for signed operand is not required      | 000000 | rs    | rt    | rd            | -             | 100000   |
| ADDI |      | Addition immediate with sign-extension, without overflow detection   | 001000 | rs    | rt    |               | const         |          |
| SUB  | R    | Subtract, overflow detection for signed operand is not required      | 000000 | rs    | rt    | rd            | -             | 100010   |
| AND  | R    | Boolean logic operation                                              | 000000 | rs    | rt    | rd            | -             | 100100   |
| ANDI |      | Boolean logic operation, zero-extension for upper 16bit of immediate | 001100 | rs    | rt    | const         |               |          |
| OR   | R    | Boolean logic operation                                              | 000000 | rs    | rt    | rd            | -             | 100101   |
| ORI  |      | Boolean logic operation, zero-extension for upper 16bit of immediate | 001000 | rs    | rt    |               | const         |          |
| XOR  | R    | Boolean logic operation                                              | 000000 | rs    | rt    | rd            | -             | 101000   |
| XORI |      | Boolean logic operation, zero-extension for upper 16bit of immediate | 001000 | rs    | rt    |               | const         |          |
| NOR  | R    | Boolean logic operation                                              | 000000 | rs    | rt    | rd            | -             | 100111   |
| SLL  | R    | Shift left logical (zero padding)                                    | 000000 | -     | rt    | rd            | shift         | 000000   |
| SRA  | R    | Shift right arithmetic (sign-digit padding)                          | 000000 | -     | rt    | rd            | shift         | 000011   |
| SRL  | R    | Shift right logical (zero padding)                                   | 000000 | -     | rt    | rd            | shift         | 000010   |
| SLT  | R    | Set less than, comparison instruction                                | 000000 | rs    | rt    | rd            | -             | 101010   |
| SLTI | l    | Set less than variable, comparison instruction                       | 001010 | rs    | rt    |               | const         |          |
| BEQ  | l    | Branch on equal, conditional branch instruction                      | 000100 | rs    | rt    |               | const         |          |
| J    | J    | Unconditionally jump                                                 | 000010 |       |       | addr          |               |          |
| JAL  | J    | Unconditionally jump and link (Save next PC in \$r31)                | 000011 |       |       | addr          | -             |          |
| JR   | R    | Unconditionally jump to the instruction whose address is in \$rs     | 000000 | rs    | -     | -             | -             | 001000   |
| JALR | R    | Jump and link register(save next PC to rd)                           | 000000 | rs    | -     | rd            | -             | 001001   |
| LW   | l    | Load word from data memory (rt=MEM([rs]+const))                      | 100011 | rs    | rt    |               | const         |          |
| SW   | l    | Store word to data memory (MEM([rs]+const)=rt)                       | 101011 | rs    | rt    |               | const         |          |
| NOP  | R    | No operation                                                         | 000000 | -     | -     | -             | -             | 000000   |



|      |      |                                                                      |        |       | addr(26)(J type) |       |                |          |  |  |  |
|------|------|----------------------------------------------------------------------|--------|-------|------------------|-------|----------------|----------|--|--|--|
|      |      |                                                                      |        |       |                  | Cr    | onst(16)(I typ | pe)      |  |  |  |
| Name | Туре | Description                                                          | OP(6)  | rs(5) | rt(5)            | rd(5) | shamt(5)       | funct(6) |  |  |  |
| ADD  | R    | Addition, overflow detection for signed operand is not required      | 000000 | rs    | rt               | rd    | -              | 100000   |  |  |  |
| ADDI | ı    | Addition immediate with sign-extension, without overflow detection   | 001000 | rs    | rt               |       | const          |          |  |  |  |
| SUB  | R    | Subtract, overflow detection for signed operand is not required      | 000000 | rs    | rt               | rd    | -              | 100010   |  |  |  |
| AND  | R    | Boolean logic operation                                              | 000000 | rs    | rt               | rd    | -              | 100100   |  |  |  |
| ANDI |      | Boolean logic operation, zero-extension for upper 16bit of immediate | 001100 | rs    | rt               | const |                |          |  |  |  |
| OR   | R    | Boolean logic operation                                              | 000000 | rs    | rt               | rd    | _              | 100101   |  |  |  |
| ORI  |      | Boolean logic operation, zero-extension for upper 16bit of immediate | 001000 | rs    | rt               |       | const          |          |  |  |  |
| XOR  | R    | Boolean logic operation                                              | 000000 | rs    | rt               | rd    |                | 101000   |  |  |  |
| XORI |      | Boolean logic operation, zero-extension for upper 16bit of immediate | 001000 | rs    | rt               |       | const          |          |  |  |  |
| NOR  | R    | Boolean logic operation                                              | 000000 | rs    | rt               | rd    | -              | 100111   |  |  |  |
| SLL  | R    | Shift left logical (zero padding)                                    | 000000 | _     | rt               | rd    | shift          | 000000   |  |  |  |
| SRA  | R    | Shift right arithmetic (sign-digit padding)                          | 000000 | -     | rt               | rd    | shift          | 000011   |  |  |  |
| SRL  | R    | Shift right logical (zero padding)                                   | 000000 | - '   | rt               | rd    | shift          | 000010   |  |  |  |
| SLT  | R    | Set less than, comparison instruction                                | 000000 | rs    | rt               | rd    | -              | 101010   |  |  |  |
| SLTI |      | Set less than variable, comparison instruction                       | 001010 | rs    | rt               |       | const          | !        |  |  |  |
| BEQ  |      | Branch on equal, conditional branch instruction                      | 000100 | rs    | rt               |       | const          |          |  |  |  |
| J    | J    | Unconditionally jump                                                 | 000010 |       |                  | addr  |                |          |  |  |  |
| JAL  | J    | Unconditionally jump and link (Save next PC in \$r31)                | 000011 |       |                  | addr  |                |          |  |  |  |
| JR   | R    | Unconditionally jump to the instruction whose address is in \$rs     | 000000 | rs    | -                |       | -              | 001000   |  |  |  |
| JALR | R    | Jump and link register(save next PC to rd)                           | 000000 | rs    |                  | rd    |                | 001001   |  |  |  |
| LW   |      | Load word from data memory (rt=MEM([rs]+const))                      | 100011 | rs    | rt               |       | const          |          |  |  |  |
| SW   |      | Store word to data memory (MEM([rs]+const)=rt)                       | 101011 | rs    | rt               |       | const          |          |  |  |  |
| NOP  | R    | No operation                                                         | 000000 | - '   | -                | -     | _              | 000000   |  |  |  |



|      |      |                                                                      |        |       | )(J type) |       |               |          |  |
|------|------|----------------------------------------------------------------------|--------|-------|-----------|-------|---------------|----------|--|
|      |      |                                                                      |        |       |           | C     | onst(16)(I ty | oe)      |  |
| Name | Туре | Description                                                          | OP(6)  | rs(5) | rt(5)     | rd(5) | shamt(5)      | funct(6) |  |
| ADD  | R    | Addition, overflow detection for signed operand is not required      | 000000 | rs    | rt        | rd    | -             | 100000   |  |
| ADDI |      | Addition immediate with sign-extension, without overflow detection   | 001000 | rs    | rt        |       | const         | -        |  |
| SUB  | R    | Subtract, overflow detection for signed operand is not required      | 000000 | rs    | rt        | rd    | -             | 100010   |  |
| AND  | R    | Boolean logic operation                                              | 000000 | rs    | rt        | rd    | -             | 100100   |  |
| ANDI | l    | Boolean logic operation, zero-extension for upper 16bit of immediate | 001100 | rs    | rt        |       | const         |          |  |
| OR   | R    | Boolean logic operation                                              | 000000 | rs    | rt        | rd    | -             | 100101   |  |
| ORI  | I    | Boolean logic operation, zero-extension for upper 16bit of immediate | 001000 | rs    | rt        |       | const         |          |  |
| XOR  | R    | Boolean logic operation                                              | 000000 | rs    | rt        | rd    | -             | 101000   |  |
| XORI | l    | Boolean logic operation, zero-extension for upper 16bit of immediate | 001000 | rs    | rt        |       | const         |          |  |
| NOR  | R    | Boolean logic operation                                              | 000000 | rs    | rt        | rd    | -             | 100111   |  |
| SLL  | R    | Shift left logical (zero padding)                                    | 000000 | _     | rt        | rd    | shift         | 000000   |  |
| SRA  | R    | Shift right arithmetic (sign-digit padding)                          | 000000 | -     | rt        | rd    | shift         | 000011   |  |
| SRL  | R    | Shift right logical (zero padding)                                   | 000000 | _     | rt        | rd    | shift         | 000010   |  |
| SLT  | R    | Set less than, comparison instruction                                | 000000 | rs    | rt        | rd    | -             | 101010   |  |
| SLTI | I    | Set less than variable, comparison instruction                       | 001010 | rs    | rt        |       | const         |          |  |
| BEQ  | I    | Branch on equal, conditional branch instruction                      | 000100 | rs    | rt        |       | const         |          |  |
| J    | J    | Unconditionally jump                                                 | 000010 |       |           | addr  |               |          |  |
| JAL  | J    | Unconditionally jump and link (Save next PC in \$r31)                | 000011 |       |           | addr  |               |          |  |
| JR   | R    | Unconditionally jump to the instruction whose address is in \$rs     | 000000 | rs    | 1         | -     | -             | 001000   |  |
| JALR | R    | Jump and link register(save next PC to rd)                           | 000000 | rs    | ı         | rd    | -             | 001001   |  |
| LW   | l    | Load word from data memory (rt=MEM([rs]+const))                      | 100011 | rs    | rt        |       | const         |          |  |
| SW   |      | Store word to data memory (MEM([rs]+const)=rt)                       | 101011 | rs    | rt        |       | const         |          |  |
| NOP  | R    | No operation                                                         | 000000 | -     | _         | _     | -             | 000000   |  |



|      |      |                                                                      |        |       | pe)   | <b>e</b> ) |                |          |
|------|------|----------------------------------------------------------------------|--------|-------|-------|------------|----------------|----------|
|      |      |                                                                      |        |       |       | C          | onst(16)(I typ | pe)      |
| Name | Туре | Description                                                          | OP(6)  | rs(5) | rt(5) | rd(5)      | shamt(5)       | funct(6) |
| ADD  | R    | Addition, overflow detection for signed operand is not required      | 000000 | rs    | rt    | rd         | -              | 100000   |
| ADDI |      | Addition immediate with sign-extension, without overflow detection   | 001000 | rs    | rt    |            | const          |          |
| SUB  | R    | Subtract, overflow detection for signed operand is not required      | 000000 | rs    | rt    | rd         | -              | 100010   |
| AND  | R    | Boolean logic operation                                              | 000000 | rs    | rt    | rd         | _              | 100100   |
| ANDI |      | Boolean logic operation, zero-extension for upper 16bit of immediate | 001100 | rs    | rt    | const      |                |          |
| OR   | R    | Boolean logic operation                                              | 000000 | rs    | rt    | rd         | -              | 100101   |
| ORI  |      | Boolean logic operation, zero-extension for upper 16bit of immediate | 001000 | rs    | rt    |            | const          |          |
| XOR  | R    | Boolean logic operation                                              | 000000 | rs    | rt    | rd         | -              | 101000   |
| XORI |      | Boolean logic operation, zero-extension for upper 16bit of immediate | 001000 | rs    | rt    |            | const          |          |
| NOR  | R    | Boolean logic operation                                              | 000000 | rs    | rt    | rd         | -              | 100111   |
| SLL  | R    | Shift left logical (zero padding)                                    | 000000 | _     | rt    | rd         | shift          | 000000   |
| SRA  | R    | Shift right arithmetic (sign-digit padding)                          | 000000 | _     | rt    | rd         | shift          | 000011   |
| SRL  | R    | Shift right logical (zero padding)                                   | 000000 | _     | rt    | rd         | shift          | 000010   |
| SLT  | R    | Set less than, comparison instruction                                | 000000 | rs    | rt    | rd         | -              | 101010   |
| SLTI |      | Set less than variable, comparison instruction                       | 001010 | rs    | rt    |            | const          |          |
| BEQ  |      | Branch on equal, conditional branch instruction                      | 000100 | rs    | rt    |            | const          |          |
| J    | J    | Unconditionally jump                                                 | 000010 |       |       | addr       |                |          |
| JAL  | J    | Unconditionally jump and link (Save next PC in \$r31)                | 000011 |       |       | addr       |                |          |
| JR   | R    | Unconditionally jump to the instruction whose address is in \$rs     | 000000 | rs    | 1     | -          | -              | 001000   |
| JALR | R    | Jump and link register(save next PC to rd)                           | 000000 | rs    | -     | rd         | -              | 001001   |
| LW   |      | Load word from data memory (rt=MEM([rs]+const))                      | 100011 | rs    | rt    |            | const          |          |
| SW   | I    | Store word to data memory (MEM([rs]+const)=[rt])                     | 101011 | rs    | rt    |            | const          |          |
| NOP  | R    | No operation                                                         | 000000 | _     | -     | -          | -              | 000000   |



|      |      |                                                                      |        | addr(26)(J type) |       |       |                |          |  |  |
|------|------|----------------------------------------------------------------------|--------|------------------|-------|-------|----------------|----------|--|--|
|      |      |                                                                      |        |                  |       | CC    | onst(16)(I typ | oe)      |  |  |
| Name | Туре | Description                                                          | OP(6)  | rs(5)            | rt(5) | rd(5) | shamt(5)       | funct(6) |  |  |
| ADD  | R    | Addition, overflow detection for signed operand is not required      | 000000 | rs               | rt    | rd    | -              | 100000   |  |  |
| ADDI |      | Addition immediate with sign-extension, without overflow detection   | 001000 | rs               | rt    |       | const          |          |  |  |
| SUB  | R    | Subtract, overflow detection for signed operand is not required      | 000000 | rs               | rt    | rd    | -              | 100010   |  |  |
| AND  | R    | Boolean logic operation                                              | 000000 | rs               | rt    | rd    | _              | 100100   |  |  |
| ANDI |      | Boolean logic operation, zero-extension for upper 16bit of immediate | 001100 | rs               | rt    | const |                |          |  |  |
| OR   | R    | Boolean logic operation                                              | 000000 | rs               | rt    | rd    | -              | 100101   |  |  |
| ORI  |      | Boolean logic operation, zero-extension for upper 16bit of immediate | 001000 | rs               | rt    |       | const          |          |  |  |
| XOR  | R    | Boolean logic operation                                              | 000000 | rs               | rt    | rd    | -              | 101000   |  |  |
| XORI |      | Boolean logic operation, zero-extension for upper 16bit of immediate | 001000 | rs               | rt    |       | const          |          |  |  |
| NOR  | R    | Boolean logic operation                                              | 000000 | rs               | rt    | rd    | -              | 100111   |  |  |
| SLL  | R    | Shift left logical (zero padding)                                    | 000000 | -                | rt    | rd    | shift          | 000000   |  |  |
| SRA  | R    | Shift right arithmetic (sign-digit padding)                          | 000000 | -                | rt    | rd    | shift          | 000011   |  |  |
| SRL  | R    | Shift right logical (zero padding)                                   | 000000 | -                | rt    | rd    | shift          | 000010   |  |  |
| SLT  | R    | Set less than, comparison instruction                                | 000000 | rs               | rt    | rd    | -              | 101010   |  |  |
| SLTI |      | Set less than variable, comparison instruction                       | 001010 | rs               | rt    |       | const          |          |  |  |
| BEQ  |      | Branch on equal, conditional branch instruction                      | 000100 | rs               | rt    |       | const          |          |  |  |
| J    | J    | Unconditionally jump                                                 | 000010 |                  |       | addr  |                |          |  |  |
| JAL  | J    | Unconditionally jump and link (Save next PC in \$r31)                | 000011 |                  |       | addr  |                |          |  |  |
| JR   | R    | Unconditionally jump to the instruction whose address is in \$rs     | 000000 | rs               | -     | _     | -              | 001000   |  |  |
| JALR | R    | Jump and link register(save next PC to rd)                           | 000000 | rs               | -     | rd    | -              | 001001   |  |  |
| LW   |      | Load word from data memory (rt=MEM([rs]+const))                      | 100011 | rs               | rt    |       | const          |          |  |  |
| SW   |      | Store word to data memory (MEM([rs]+const)=[rt])                     | 101011 | rs               | rt    |       | const          |          |  |  |
| NOP  | R    | No operation                                                         | 000000 | -                | -     | -     | _              | 000000   |  |  |



|      |      |                                                                      |        | addr(26)(J type) |       |       |                |          |  |  |
|------|------|----------------------------------------------------------------------|--------|------------------|-------|-------|----------------|----------|--|--|
|      |      |                                                                      |        |                  |       | C     | onst(16)(I typ | oe)      |  |  |
| Name | Туре | Description                                                          | OP(6)  | rs(5)            | rt(5) | rd(5) | shamt(5)       | funct(6) |  |  |
| ADD  | R    | Addition, overflow detection for signed operand is not required      | 000000 | rs               | rt    | rd    | -              | 100000   |  |  |
| ADDI |      | Addition immediate with sign-extension, without overflow detection   | 001000 | rs               | rt    |       | const          |          |  |  |
| SUB  | R    | Subtract, overflow detection for signed operand is not required      | 000000 | rs               | rt    | rd    | -              | 100010   |  |  |
| AND  | R    | Boolean logic operation                                              | 000000 | rs               | rt    | rd    | _              | 100100   |  |  |
| ANDI |      | Boolean logic operation, zero-extension for upper 16bit of immediate | 001100 | rs               | rt    | const |                |          |  |  |
| OR   | R    | Boolean logic operation                                              | 000000 | rs               | rt    | rd    | -              | 100101   |  |  |
| ORI  |      | Boolean logic operation, zero-extension for upper 16bit of immediate | 001000 | rs               | rt    |       | const          | -        |  |  |
| XOR  | R    | Boolean logic operation                                              | 000000 | rs               | rt    | rd    | -              | 101000   |  |  |
| XORI |      | Boolean logic operation, zero-extension for upper 16bit of immediate | 001000 | rs               | rt    |       | const          |          |  |  |
| NOR  | R    | Boolean logic operation                                              | 000000 | rs               | rt    | rd    | -              | 100111   |  |  |
| SLL  | R    | Shift left logical (zero padding)                                    | 000000 | -                | rt    | rd    | shift          | 000000   |  |  |
| SRA  | R    | Shift right arithmetic (sign-digit padding)                          | 000000 | _                | rt    | rd    | shift          | 000011   |  |  |
| SRL  | R    | Shift right logical (zero padding)                                   | 000000 | -                | rt    | rd    | shift          | 000010   |  |  |
| SLT  | R    | Set less than, comparison instruction                                | 000000 | rs               | rt    | rd    | -              | 101010   |  |  |
| SLTI |      | Set less than variable, comparison instruction                       | 001010 | rs               | rt    |       | const          |          |  |  |
| BEQ  |      | Branch on equal, jump to PC+4+4*const                                | 000100 | rs               | rt    |       | const          |          |  |  |
| J    | J    | Unconditionally jump                                                 | 000010 |                  | -     | addr  |                |          |  |  |
| JAL  | J    | Unconditionally jump and link (Save next PC in \$r31)                | 000011 |                  |       | addr  |                |          |  |  |
| JR   | R    | Unconditionally jump to the instruction whose address is in \$rs     | 000000 | rs               | -     | -     | -              | 001000   |  |  |
| JALR | R    | Jump and link register(save next PC to rd)                           | 000000 | rs               | -     | rd    | -              | 001001   |  |  |
| LW   |      | Load word from data memory (rt=MEM([rs]+const))                      | 100011 | rs               | rt    |       | const          |          |  |  |
| SW   |      | Store word to data memory (MEM([rs]+const)=[rt])                     | 101011 | rs               | rt    |       | const          |          |  |  |
| NOP  | R    | No operation                                                         | 000000 | -                | -     | -     | -              | 000000   |  |  |



|      |      |                                                                      |        | ac    | addr(26)(J type) |       |                |          |  |  |  |
|------|------|----------------------------------------------------------------------|--------|-------|------------------|-------|----------------|----------|--|--|--|
|      |      |                                                                      |        |       |                  | C     | onst(16)(I typ | oe)      |  |  |  |
| Name | Type | Description                                                          | OP(6)  | rs(5) | rt(5)            | rd(5) | shamt(5)       | funct(6) |  |  |  |
| ADD  | R    | Addition, overflow detection for signed operand is not required      | 000000 | rs    | rt               | rd    | -              | 100000   |  |  |  |
| ADDI |      | Addition immediate with sign-extension, without overflow detection   | 001000 | rs    | rt               |       | const          |          |  |  |  |
| SUB  | R    | Subtract, overflow detection for signed operand is not required      | 000000 | rs    | rt               | rd    | -              | 100010   |  |  |  |
| AND  | R    | Boolean logic operation                                              | 000000 | rs    | rt               | rd    | _              | 100100   |  |  |  |
| ANDI |      | Boolean logic operation, zero-extension for upper 16bit of immediate | 001100 | rs    | rt               | const |                |          |  |  |  |
| OR   | R    | Boolean logic operation                                              | 000000 | rs    | rt               | rd    | -              | 100101   |  |  |  |
| ORI  |      | Boolean logic operation, zero-extension for upper 16bit of immediate | 001000 | rs    | rt               |       | const          | -        |  |  |  |
| XOR  | R    | Boolean logic operation                                              | 000000 | rs    | rt               | rd    | -              | 101000   |  |  |  |
| XORI |      | Boolean logic operation, zero-extension for upper 16bit of immediate | 001000 | rs    | rt               |       | const          |          |  |  |  |
| NOR  | R    | Boolean logic operation                                              | 000000 | rs    | rt               | rd    | -              | 100111   |  |  |  |
| SLL  | R    | Shift left logical (zero padding)                                    | 000000 | -     | rt               | rd    | shift          | 000000   |  |  |  |
| SRA  | R    | Shift right arithmetic (sign-digit padding)                          | 000000 | _     | rt               | rd    | shift          | 000011   |  |  |  |
| SRL  | R    | Shift right logical (zero padding)                                   | 000000 | -     | rt               | rd    | shift          | 000010   |  |  |  |
| SLT  | R    | Set less than, comparison instruction                                | 000000 | rs    | rt               | rd    | -              | 101010   |  |  |  |
| SLTI |      | Set less than variable, comparison instruction                       | 001010 | rs    | rt               |       | const          |          |  |  |  |
| BEQ  |      | Branch on equal, jump to PC+4+4*const                                | 000100 | rs    | rt               |       | const          |          |  |  |  |
| J    | J    | Unconditionally jump                                                 | 000010 |       |                  | addr  |                |          |  |  |  |
| JAL  | J    | Unconditionally jump and link (Save next PC in \$r31)                | 000011 |       |                  | addr  |                |          |  |  |  |
| JR   | R    | Unconditionally jump to the instruction whose address is in \$rs     | 000000 | rs    | -                | -     | -              | 001000   |  |  |  |
| JALR | R    | Jump and link register(save next PC to rd)                           | 000000 | rs    | -                | rd    | -              | 001001   |  |  |  |
| LW   |      | Load word from data memory (rt=MEM([rs]+const))                      | 100011 | rs    | rt               |       | const          |          |  |  |  |
| SW   |      | Store word to data memory (MEM([rs]+const)=[rt])                     | 101011 | rs    | rt               |       | const          |          |  |  |  |
| NOP  | R    | No operation                                                         | 000000 | -     | -                | -     | -              | 000000   |  |  |  |



|      |      |                                                                      | dr(26)(J ty | 26)(J type) |       |       |               |          |
|------|------|----------------------------------------------------------------------|-------------|-------------|-------|-------|---------------|----------|
|      |      |                                                                      |             |             |       | co    | nst(16)(I typ | pe)      |
| Name | Туре | Description                                                          | OP(6)       | rs(5)       | rt(5) | rd(5) | shamt(5)      | funct(6) |
| ADD  | R    | Addition, overflow detection for signed operand is not required      | 000000      | rs          | rt    | rd    | -             | 100000   |
| ADDI |      | Addition immediate with sign-extension, without overflow detection   | 001000      | rs          | rt    |       | const         |          |
| SUB  | R    | Subtract, overflow detection for signed operand is not required      | 000000      | rs          | rt    | rd    | -             | 100010   |
| AND  | R    | Boolean logic operation                                              | 000000      | rs          | rt    | rd    | -             | 100100   |
| ANDI |      | Boolean logic operation, zero-extension for upper 16bit of immediate | 001100      | rs          | rt    | const |               |          |
| OR   | R    | Boolean logic operation                                              | 000000      | rs          | rt    | rd    | -             | 100101   |
| ORI  |      | Boolean logic operation, zero-extension for upper 16bit of immediate | 001000      | rs          | rt    |       | const         |          |
| XOR  | R    | Boolean logic operation                                              | 000000      | rs          | rt    | rd    | -             | 101000   |
| XORI |      | Boolean logic operation, zero-extension for upper 16bit of immediate | 001000      | rs          | rt    |       | const         |          |
| NOR  | R    | Boolean logic operation                                              | 000000      | rs          | rt    | rd    | -             | 100111   |
| SLL  | R    | Shift left logical (zero padding)                                    | 000000      | _           | rt    | rd    | shift         | 000000   |
| SRA  | R    | Shift right arithmetic (sign-digit padding)                          | 000000      | _           | rt    | rd    | shift         | 000011   |
| SRL  | R    | Shift right logical (zero padding)                                   | 000000      | -           | rt    | rd    | shift         | 000010   |
| SLT  | R    | Set less than, comparison instruction                                | 000000      | rs          | rt    | rd    | -             | 101010   |
| SLTI |      | Set less than variable, comparison instruction                       | 001010      | rs          | rt    |       | const         |          |
| BEQ  |      | Branch on equal, jump to PC+4+4*const                                | 000100      | rs          | rt    |       | const         |          |
| J    | J    | Unconditionally jump                                                 | 000010      |             |       | addr  |               |          |
| JAL  | J    | Unconditionally jump and link (Save next PC in \$r31)                | 000011      |             |       | addr  |               |          |
| JR   | R    | Unconditionally jump to the instruction whose address is in \$rs     | 000000      | rs          | ı     | -     | -             | 001000   |
| JALR | R    | Jump and link register(save next PC to rd)                           | 000000      | rs          | •     | rd    | -             | 001001   |
| LW   |      | Load word from data memory (rt=MEM([rs]+const))                      | 100011      | rs          | rt    |       | const         |          |
| SW   |      | Store word to data memory (MEM([rs]+const)=[rt])                     | 101011      | rs          | rt    |       | const         |          |
| NOP  | R    | No operation                                                         | 000000      | -           | -     | -     | -             | 000000   |





|      |      |                                                                      |        | addr(26)(J type) |       |       |               |          |  |  |  |
|------|------|----------------------------------------------------------------------|--------|------------------|-------|-------|---------------|----------|--|--|--|
|      |      |                                                                      |        |                  |       | CC    | nst(16)(I typ | pe)      |  |  |  |
| Name | Type | Description                                                          | OP(6)  | rs(5)            | rt(5) | rd(5) | shamt(5)      | funct(6) |  |  |  |
| ADD  | R    | Addition, overflow detection for signed operand is not required      | 000000 | rs               | rt    | rd    | -             | 100000   |  |  |  |
| ADDI |      | Addition immediate with sign-extension, without overflow detection   | 001000 | rs               | rt    |       | const         |          |  |  |  |
| SUB  | R    | Subtract, overflow detection for signed operand is not required      | 000000 | rs               | rt    | rd    | -             | 100010   |  |  |  |
| AND  | R    | Boolean logic operation                                              | 000000 | rs               | rt    | rd    | -             | 100100   |  |  |  |
| ANDI |      | Boolean logic operation, zero-extension for upper 16bit of immediate | 001100 | rs               | rt    | const |               |          |  |  |  |
| OR   | R    | Boolean logic operation                                              | 000000 | rs               | rt    | rd    | -             | 100101   |  |  |  |
| ORI  |      | Boolean logic operation, zero-extension for upper 16bit of immediate | 001000 | rs               | rt    |       | const         |          |  |  |  |
| XOR  | R    | Boolean logic operation                                              | 000000 | rs               | rt    | rd    | -             | 101000   |  |  |  |
| XORI |      | Boolean logic operation, zero-extension for upper 16bit of immediate | 001000 | rs               | rt    |       | const         |          |  |  |  |
| NOR  | R    | Boolean logic operation                                              | 000000 | rs               | rt    | rd    | -             | 100111   |  |  |  |
| SLL  | R    | Shift left logical (zero padding)                                    | 000000 | -                | rt    | rd    | shift         | 000000   |  |  |  |
| SRA  | R    | Shift right arithmetic (sign-digit padding)                          | 000000 | -                | rt    | rd    | shift         | 000011   |  |  |  |
| SRL  | R    | Shift right logical (zero padding)                                   | 000000 | -                | rt    | rd    | shift         | 000010   |  |  |  |
| SLT  | R    | Set less than, comparison instruction                                | 000000 | rs               | rt    | rd    | -             | 101010   |  |  |  |
| SLTI |      | Set less than variable, comparison instruction                       | 001010 | rs               | rt    |       | const         |          |  |  |  |
| BEQ  |      | Branch on equal, jump to PC+4+4*const                                | 000100 | rs               | rt    |       | const         |          |  |  |  |
| J    | J    | Unconditionally jump                                                 | 000010 |                  |       | addr  |               |          |  |  |  |
| JAL  | J    | Unconditionally jump and link (Save next PC in \$r31)                | 000011 |                  |       | addr  |               |          |  |  |  |
| JR   | R    | Unconditionally jump to the instruction whose address is in \$rs     | 000000 | rs               | -     | -     | -             | 001000   |  |  |  |
| JALR | R    | Jump and link register(save next PC to rd)                           | 000000 | rs               | -     | rd    | -             | 001001   |  |  |  |
| LW   |      | Load word from data memory (rt=MEM([rs]+const))                      | 100011 | rs               | rt    |       | const         |          |  |  |  |
| SW   |      | Store word to data memory (MEM([rs]+const)=[rt])                     | 101011 | rs               | rt    |       | const         |          |  |  |  |
| NOP  | R    | No operation                                                         | 000000 | -                | -     | -     | -             | 000000   |  |  |  |



|      |      |                                                                      |        |       |       | ac                | ddr(26)(J ty | pe)      |  |
|------|------|----------------------------------------------------------------------|--------|-------|-------|-------------------|--------------|----------|--|
|      |      |                                                                      |        |       |       | const(16)(I type) |              |          |  |
| Name | Туре | Description                                                          | OP(6)  | rs(5) | rt(5) | rd(5)             | shamt(5)     | funct(6) |  |
| ADD  | R    | Addition, overflow detection for signed operand is not required      | 000000 | rs    | rt    | rd                | -            | 100000   |  |
| ADDI |      | Addition immediate with sign-extension, without overflow detection   | 001000 | rs    | rt    |                   | const        |          |  |
| SUB  | R    | Subtract, overflow detection for signed operand is not required      | 000000 | rs    | rt    | rd                | -            | 100010   |  |
| AND  | R    | Boolean logic operation                                              | 000000 | rs    | rt    | rd                | _            | 100100   |  |
| ANDI |      | Boolean logic operation, zero-extension for upper 16bit of immediate | 001100 | rs    | rt    | const             |              |          |  |
| OR   | R    | Boolean logic operation                                              | 000000 | rs    | rt    | rd                | -            | 100101   |  |
| ORI  |      | Boolean logic operation, zero-extension for upper 16bit of immediate | 001000 | rs    | rt    |                   | const        |          |  |
| XOR  | R    | Boolean logic operation                                              | 000000 | rs    | rt    | rd                | _            | 101000   |  |
| XORI |      | Boolean logic operation, zero-extension for upper 16bit of immediate | 001000 | rs    | rt    |                   | const        |          |  |
| NOR  | R    | Boolean logic operation                                              | 000000 | rs    | rt    | rd                | -            | 100111   |  |
| SLL  | R    | Shift left logical (zero padding)                                    | 000000 | -     | rt    | rd                | shift        | 000000   |  |
| SRA  | R    | Shift right arithmetic (sign-digit padding)                          | 000000 | -     | rt    | rd                | shift        | 000011   |  |
| SRL  | R    | Shift right logical (zero padding)                                   | 000000 | -     | rt    | rd                | shift        | 000010   |  |
| SLT  | R    | Set less than, comparison instruction                                | 000000 | rs    | rt    | rd                | -            | 101010   |  |
| SLTI |      | Set less than variable, comparison instruction                       | 001010 | rs    | rt    |                   | const        |          |  |
| BEQ  |      | Branch on equal, jump to PC+4+4*const                                | 000100 | rs    | rt    |                   | const        |          |  |
| J    | J    | Unconditionally jump                                                 | 000010 |       |       | addr              |              |          |  |
| JAL  | J    | Unconditionally jump and link (Save next PC in \$r31)                | 000011 |       |       | addr              |              |          |  |
| JR   | R    | Unconditionally jump to the instruction whose address is in \$rs     | 000000 | rs    | -     | -                 | -            | 001000   |  |
| JALR | R    | Jump and link register(save next PC to rd)                           | 000000 | rs    | -     | rd                | -            | 001001   |  |
| LW   |      | Load word from data memory (rt=MEM([rs]+const))                      | 100011 | rs    | rt    |                   | const        |          |  |
| SW   |      | Store word to data memory (MEM([rs]+const)=[rt])                     | 101011 | rs    | rt    |                   | const        |          |  |
| NOP  | R    | No operation                                                         | 000000 | -     | -     | -                 | -            | 000000   |  |





- Design Specification
- Hardware
  - Cache Implementation
  - MIPS Implementation
    - Instructions
    - Hazard Handling
  - Performance

| Туре            | Solution              |
|-----------------|-----------------------|
| Data Hazard     | Forwarding            |
| Memory Stall    | Stall                 |
| Load-use Hazard | Insert Bubble & Stall |
| Jump/Branch     | Flush                 |



| Туре            | Solution              |
|-----------------|-----------------------|
| Data Hazard     | Forwarding            |
| Memory Stall    | Stall                 |
| Load-use Hazard | Stall & Insert Bubble |
| Jump/Branch     | Flush                 |



| Туре            | Solution              |
|-----------------|-----------------------|
| Data Hazard     | Forwarding            |
| Memory Stall    | Stall                 |
| Load-use Hazard | Insert Bubble & Stall |
| Jump/Branch     | Flush                 |







| Type                           | Solution              |
|--------------------------------|-----------------------|
| Data Hazard                    | Forwarding            |
| Memory Stall                   | Stall                 |
| Load-use Hazard                | Insert Bubble & Stall |
| Branch Hazard<br>(BEQ/JR/JALR) | Flush                 |



- Design Specification
- Hardware
  - Cache Implementation
  - MIPS Implementation
    - Instructions
    - Hazard Handling
  - Performance

# Synthesis Result

- Using TSMC 0.13um technology
  - Minimum clock cycle: 3.5ns
  - Total simulation time of the testbench: 7145.25 ns
  - 286617um<sup>2</sup>

